## **LAB 4**

## OBJECTIVE: To design and simulate a NAND gate using VHDL, and verify its functionality using a testbench.

## TOOLS USED:

* VHDL (VHSIC Hardware Description Language)
* <https://www.edaplayground.com/> (for simulation)

**THEORY:**

The aim of this lab is to create a NAND gate in VHDL and simulate it using a testbench. The design code describes the logic of the NAND gate, and the testbench applies both possible input combinations to validate the behavior of the gate.

## VHDL CODE

**DESIGN**

library ieee;

use ieee.std\_logic\_1164.all;

entity nandgate is

port(

a,b:in std\_logic;

c: out std\_logic

);

end nandgate;

architecture behavior of nandgate is

begin

c <= not (a and b);

end behavior;

**TESTBENCH**

library ieee;

use ieee.std\_logic\_1164.all;

entity nandgate\_testbench is

end nandgate\_testbench;

architecture test of nandgate\_testbench is

component nandgate

port(

a,b: in std\_logic;

c: out std\_logic

);

end component;

signal ak,bk,ck: std\_logic;

begin

nand\_gate: nandgate port map(a=>ak, b=>bk, c=>ck);

process begin

ak <= '0';bk <= '0';wait for 1 ns;

ak <= '0';bk <= '1';wait for 1 ns;

ak <= '1';bk <= '0';wait for 1 ns;

ak <= '1';bk <= '1';wait for 1 ns;

assert false report "Completed successfully";

wait;

end process;

end test;

Output:

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAm4AAABTCAIAAACpsRweAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAFf0lEQVR4nO3dP2wb1x0H8B+LLFqkCG4AGkGE2EDduAVq1J6i0fGSNfVgwPIQ2Au5yAZ3DtyJ2gu5yM4gGfAQZMtGa1SmqEmLiq0DOIUCwwIMgxYXjdeBlpBEf5kTdXfU5zMJ0pPww/vh9MW9945XSpIkAIDfqlSpVLKuYW+tVrtazWlt/IpmFYhmFYVOFcjvsi4AAIpNlAJAKqIUAFIRpQCQyjtZF3AEV79vXl+ZiIit2a9qlzpZl8PBrt198tmF369Ury0dOGyu3p4tR0RsfFNpLA6+159vPv7jRERM//fLGw+WI0L3R2dntg+fW83K1s7861Ru5T9K1+vXX/2jWlmKiFudVn2905jJuiT2cfX75vWVeDa7Ea8OHnjt7pO/9m9WG5MR/fnmk/kXNx4sx1z98dR3lepiRKzXW5255WtLuj9Ckw9qb0+HztXbn94917k/uec4zcrcUqOyFDEIxdlblzqLew/TqQzlfoH31rPy1nsbg69fvLdVfjaXbT0cYPlSrVqp3Z8+bFz/zx/0Nl8P/nFPvt7szfylH7F+vjy9+WIw4N3NrR/O39L9k9E/MxXb7djjp5qVG2+mJnamfTedylLuo/Tnlqc3sy6BY7fR3x29k693d1r3R2Ou/njmp5uNfW50fkWzMrJeb7Vbra/jm+0V2sPo1AkrVJRe7U1lXQLHrjzZ2/W9/pndndb949efb7bP/1ip7bO0u5tmZWSmUa1Uq5Xn59rNu/2j/IJOnbDcR+nihY2JV4Md93j/1cTGhYMPs5BPc/V2q9XZXkea/PdP01NnBv8R+memptf/ORkx83yjN/X+YMCbqYk/PF/U/dEa7KLtvh/VrKLQqfzI/7GjmcaXvWarPRuDw2a2x3Ns51hgRLn1w+zPTwz+Uuf+jXK93WpFDI4aLkdELDVuzjfbrY9jcNRwKUL3R2n9fDnK5cGEx9azm/vdm2pW1n551rqx7xKCTmVoHD6Dd6hPqhzFn1XqEQav15u9ldqlz8xVAQoYYbMKNFdFKPVtpzpZz0AR5mrokUMNzv0CL2Nhrv51fOfxtWLQrKLQqfzI/wIv42CpkdPFD3bTrKLQqfxwVwoAqYhSAEgl18eOsi4BAA6X3ygFgEKwwAsAAEB2SlkXAJy0y99ezroEACgsOQrHzl4pAKQiSgEgFVEKAKmIUgBIRZQCQCqiFABSOXKU3nvaS7Z1F0ZZEgCMuYW1ZE2WQkF5rhSO3RALvAvdwT3p7YujKwcAiuaoUVpb7t2Oh6VSqVR62B1pRQBQKEeN0otn333zshsRce/c2RHWAwDjaufYUe/p026S2C6FYrJXCgCpiFI4dp4rBYBU3sm6gMMkSdYVwHhZvRJJEiXvKgYAAAAAAE47+yUcG0dDC2T1ymrWJXA41xScIi74InGUryBcVgXiYRgASEWUAkAqohQAUhGlAJDKUaN0oZusPRppJQBQSO5KASCVoaJ0YW3wnrWuF6wBwFtDROnFz2dXSqVS6WH3o9sWewFgYIgo7X7xpzsREXdW/hNnP6yNqiIAKJTfuFf68n/N460DAApqmAXejxciIu49/dtHb17+a1QFAUCxDPHq727MJkkSEd0vSp/8fWQVAUChHDVK71z0DhkA2IPnSgEglSEWeLPhhVCFsHolkiRKli6Kw5WVfy4rAAAAAAAYsbyvwl/+9nLWJQBkZvXKatYlAEBBORpWHB6GAYBURCkApCJKASAVUQoAqYhSAEhFlAJAKkNEaW25l2xbezS6kgBgLD1aS5K1hayrADgtPFc6fha6SW+5lnUVAKeGKC0Oe6UAcDIs8AKcJHelY8mxI4CTI0oBIBVRWhz2SgEglby/rxTglHJXCgAAAByulFhDAIAUHDsCgFT+D/SzLf0IfQxkAAAAAElFTkSuQmCC)

CONCLUSION:

The NOT gate was successfully simulated. The output matched the expected behavior where ck is the inverse of ak for all input combinations. The use of a simple testbench allowed for effective verification of the circuit behavior in a VHDL simulation environment.